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SCAN SYNCHRONIZED DUAL FRAME BUFFER GRAPHICS SUBSYSTEM 
BACKGROUND OF THE INVENTION 

Field of the Invention 

The invention relates generally to the field of computer graphics and, more 
5 particularly to, a method and apparatus for efficiently displaying pixels stored in a dual 
frame buffer graphics subsystem. 

Background Information 

Generally, in computer graphic systems, a frame buffer is implemented in 

10 conjunction with a computer display monitor. For the displayed image to be visible, the 
frame buffer's entire contents need to be transferred to the display continuously. In 
particular, the frame buffer contains pixels in a digitized form for display on the 
corresponding monitor. The pixel data is arranged in the frame buffer in rows and 
columns that correspond to rows and columns on the display monitor. To display a 

15 graphical image on the display monitor, the pixel data is transferred from the frame 

buffer memory and converted to an analog signal by a digital to analog converter (DAC). 
In a system having multi-format pixel data, each pixel format must be converted to a 
standard format for the video monitor before conversion to the analog signal. The analog 
signal is input to the display monitor to generate the graphical display. 

20 The size and performance of the frame buffer is dictated by a number of factors 

including, but not limited to, the display refresh, number of monitor pixels, monitor clock 
rate, data read/write frequency, and memory bandwidth. For high-resolution systems, the 
display refresh process consumes an appreciable portion of the total bandwidth available 
from the memory. During display refresh, pixel data is retrieved out of the frame buffer 

25 by the display controller pixel by pixel as the corresponding pixels on the display are 
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refreshed. The size of the frame buffer thus directly corresponds to the number of pixels 
in each display frame and the number of bits in each word used to define each pixel. 

Chipset integrated graphics controllers are increasingly being implemented in a 
uniform memory architecture (UMA) in which the frame buffer memory is part of the 
main system memory. In particular, in order to contain costs, the frame buffer and the 
system memory are incorporated into a unified or shared memory, thus allowing 
manufacturers of computer equipment to reduce costs by eliminating the need for a 
separate memory for the frame buffer. Incorporating the frame buffer and the system 
memory within a shared memory is furthermore desirable, as it allows unused portions of 
the frame buffer to be employed as a system memory when all, or even a portion, of the 
frame buffer is not in use. A UMA is typically implemented by providing an array of 
DRAM accessible by both the memory controller and the graphics controller, the 
associated memory space of the DRAM array being partitioned between system memory 
and the frame buffer. 

While the implementation of the UMA provides a number of cost benefits, such 
memory configurations suffer from a lowered memory bandwidth, as the frame buffer 
memory bandwidth is typically constrained by the speed of the memory devices 
available. While the UMA has significant advantages regarding cost and flexibility, the 
additional drain on memory bandwidth caused by the constant need to maintain screen 
refresh may impact overall performance. As display rates and screen resolutions 
increase, performance is more seriously impacted. The frame buffer is simultaneously 
being burdened with other tasks such as cell refresh, off-screen memory accesses and 
writes to the on-screen memory. In some cases, the degradation of performance to the 
cenfral processing unit (CPU) caused by the reduced effective memory bandwidth can be 
a significant problem for a conventional 1280 by 1024 pixel display operating at a refresh 
frequency of 85 Hz. 

One potential solution to the bandwidth problem is to integrate the frame buffer, 
- which is. typically constructed from a dynamic random access memoryj(DRAM). device^... 
into the graphics component. In particular, an integrated DRAM is used as the frame 
buffer for the display, lessening the bandwidth load on the main system memory. 
However, this solution is generally commercially unviable in that the cost of integrating a 



large capacity DRAM on a graphics controller is too high. Most graphics controllers 
today use external graphics memory that is 16 MB or greater in size. The large DRAM 
capacity is needed for the double and triple buffering of the frame buffer that software 
applications require, plus the additional off-screen storage of textures and so forth. 
Consequently, the cost of integrating 16 MB or 32 MB of DRAM on a graphics controller 
is too high to be a practical solution. 

What is needed therefore is a system and method for integrating chipset integrated 
graphics controllers onto a UMA without negatively impacting performance or cost. 

BRIEF DESCRIPTION OF THE DRAWINGS 

FIG. 1 is a block diagram of showing a computer system in which the scan 
synchronized dual frame buffer architecture can be implemented. 

FIG. 2(a) is an illustration of the operation of a tile copy when a set of pixels is 
updated in the primary frame buffer in frame N. 

FIG. 2(b) is an illustration of the operation of a tile copy when a set of pixels is 
updated in the primary frame buffer in frame N+1 . 

FIG. 3 is a flowchart of an algorithm for implementing the scan synchronized dual 
frame buffer architecture illustrated in FIG. 1. 

DETAILED DESCRIPTION OF THE ILLUSTRATED EMBODIMENTS 

Referring to FIG. 1, the present invention provides a frame buffer architecture 10 
including primary and secondary frame buffers 12 and 14, respectively, corresponding to 
a display 11. The primary frame buffer 12 is implemented as part of a unified memory 
architecture (UMA) memory 16, residing anywhere within the system memory space, and 
the secondary frame buffer 14 is implemented on a chipset/graphics component 18 that is 
in communication with the UMA memory 16. The primary frame buffer 12 maintains an 
image on a display 11 . In operation, changing a pixel in the primary frame buffer 12 
causes the corresponding pixel on the display 1 1 to change. In particular, the secondary 
frame buffer 14 maintains various functions, including display refresh, thus alleviating 
the bandwidth demands on the primary frame buffer 12 and the main system memory 16. 



One skilled in the art will recognize that the secondary frame buffer 14 could be adapted 
to perform other operations that require bandwidth, including but not limited to, drawing 
operations. 

In a typical operation, not every pixel in the frame buffer is changing on every 
5 complete scan of the display 1 1 . Consequently, most of the bandwidth for maintaining 
the display 1 1 would be handled by the secondary frame buffer 14, returning substantially 
all of the bandwidth back to the UMA memory 16, The extra bandwidth for the primary 
frame buffer 12 can be used for handling the background tasks of the operating system, 
local area network, three-dimensional calculations, virus scan, and so forth. Additionally, 
1 0 there are significant power savings gained by removing the display refresh activity from 
the UMA memory 16. 

In operation, when a pixel is changed in the primary frame buffer 12, that pixel is 
copied to the secondary frame buffer 14 when the pixel is needed by the display 1 1 . In 
particular, the pixel is transmitted simultaneously to the digital to analog converter 
15 (DAC) 22 and the secondary frame buffer 14, synchronized to the display refresh. This 
action mimics the effect the primary frame buffer 12 would have on the display 1 1 if the 
primary frame buffer 12 were the actual frame buffer maintaining the display 11. 

The present invention is not dependent upon where the primary and secondary 
frame buffers 12 and 14, respectively, are implemented. For illustrative purposes, 
20 however, the present invention is described and illustrated with the primary frame buffer 
12 implemented as part of a unified memory architecture (UMA) memory 16, residing 
anywhere within the system memory space, and the secondary frame buffer 14 
implemented on a chipset/graphics component 18 that is in communication with the 
UMA memory 16. 

25 The UMA memory 16 is typically implemented by providing an array of DRAM 

accessible by at least the primary frame buffer detector 20 and the memory controller 32, 
the associated memory space of the DRAM array being partitioned between system 
memory and the primary frame buffer 12. It will be appreciated that the size and location 
of the primary frame buffer 12 within the UMA memory 16 are definable and can be 

30 modified depending on the requirements of the computer system. The secondary frame 
buffer 14 can be implemented utilizing a minimal amount of memory, thus requiring less 
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memory integration on the chipset/graphics component 18. In a typical embodiment, the 
width of the secondary frame buffer memory, typically a dynamic random access 
memory (DRAM), need only be twenty- four (24) bits since its primary function is to 
maintain images on the display 11. The 24 bits would be allocated to RGB, with eight 
5 (8) bits allocated for each color component. 

Referring to FIG. 1, the chipset/graphics component 18 includes a primary frame 
buffer detector 20, DAC 22, CRT timing generator 24, FIFO 26, secondary frame buffer 
address generator 28, 2D/3D engine 30 and memory controller 32. The primary frame 
buffer detector 20 detects changes in the primary frame buffer 12 and copies those 

10 changes to the secondary frame buffer 14. The pixels fetched from the primary frame 
buffer 12 are eventually fed to the FIFO 26 and then passed on to the DAC 22, which 
converts the pixels into analog RGB signals for use by the display 1 1 . In this manner, the 
pixels in the primary frame buffer 12 appear on the screen in their proper position and the 
displayed image is maintained. 

1 5 The primary frame buffer detector 20 includes a primary frame buffer address 

generator 34, touched tile detector 36, touched tile map 38 and tile access channel 40. 
The CRT timing generator 24 is coupled to the DAC 22, primary frame buffer address 
generator 34 and secondary frame buffer address generator 28. In operation, the CRT 
timing generator 24 creates the synchronization timing for the display 1 1 as well as the X 

20 and Y position indicators on the CRT beam position. The X and Y position indicators are 
fed from the CRT timing generator 24 to the primary frame buffer address generator 34 
in order to convert the X and Y positions into addresses used to fetch pixels from the 
primary frame buffer 12. 

A pixel may be updated in the primary frame buffer 12 via the memory controller 

25 32 or the 2D/3D engine 30 or some manner well known in the art. The memory 

controller 32 is coupled to the UMA memory 16 by a bus, which includes control and 
address lines, which are coupled to the control, address and data lines of the UMA 
memory. The memory controller 32 accesses the primary frame buffer 12 within the 
UMA memory 16 for the purposes of storing and retrieving graphics data therein for 

30 ultimate display on a the display device 1 1 which is coupled to the chipset/graphics 
component 18. The memory controller 32 receives graphics, data and commands via a 
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peripheral bus. Such graphics, data and commands originate from a processor or a 
number of other devices or components connected to the peripheral bus, in a manner well 
known in the art. 

Referring to FIGS. 1 and 2(a)-(b), the primary frame buffer 12 is divided into 
5 smaller regions called tiles 42, Tiles 42 are areas of the screen that represent blocks of 
pixels. The tiles are generally rectangular shaped areas although one skilled in the art 
will recognize that they may be of any geometric shape. The present invention is not 
dependent on the size of the tiles 42, which can be any size, including a single pixel. 
Generally, smaller tiles 42 require a larger touched tile map 38 while larger tiles 42 

1 0 require a smaller touched tile map 38. 

When a pixel is updated (e.g. such as by a user inputting a letter from a 
keyboard), the memory controller 32 and/or 2D/3D engine 30 notifies the primary frame 
buffer detector 20 and primary frame buffer address generator 34. The primary frame 
buffer address generator 34 determines the updated pixel's address and notifies the 

1 5 touched tile detector 36. The touched tile detector 36 decodes the pixel's address and 
updates the touched tile map 38. Any pixel that is updated (i.e. touched) in the primary 
frame buffer 12 causes all the pixels in its tile 42 to be tagged for copying to the 
secondary frame buffer 14 at the next pass of the CRT beam. 

As the display 1 1 is being refreshed, the CRT timing generator 24 provides the X 

20 and Y position information to the primary frame buffer address generator 34, which is in 
communication with the touched tile map 38. This information is used to fetch the proper 
location in the touched tile map 38 to pass on to the touched tile detector 36. If the 
display 1 1 is about to cover an area of a tile 42 that has been updated (i.e. touched), the 
touched tile detector 36 will signal the tile access channel 40, secondary frame buffer 

25 address generator 28 and FIFO 26 to pass the data from the primary frame buffer 12 to 
the DAC 22 and the secondary frame buffer 14. 

Referring to FIGS. 2(a) and (b), the operation of the present invention is 
illustrated with a set of pixels that are updated in the primary frame buffer 12. In 
particular, the user is attempting to input the letters for the word "Test". Referring to 

30 FIG. 2(a), in "Frame N", the letters "Tes" have been sitting in both the primary and 
secondary frame buffers 12 and 14 for many milliseconds because of previous copy 



6 



operations. Frame N no longer has any "touched" tiles 42 from the primary frame 
buffer 12 since the image has been stable for many milliseconds. 

Referring to FIG. 2(b), in "Frame N+l", sometime after the CRT beam has passed 
the letters "Tes" in "Frame N", the final "t" is drawn in the primary frame buffer 12. The 
5 shaded tiles 44 are the tiles associated with the letter "t" that will be fetched from the 
primary frame buffer 12 for display and simultaneously copied to the secondary frame 
buffer 14. This action tags the shaded tiles 44 as touched. When Frame N+1 is displayed 
on the monitor, the shaded areas 44 will come from the primary frame buffer 12 and will 
be simultaneously written into the secondary frame buffer 14. The memory holding the 

10 primary frame buffer 12 will suffer a small impact on its available bandwidth as the 

information is fetched. After the copy operation is completed, the display 1 1 reverts back 
to fetching pixels only from the secondary frame buffer 14 and the touched tiles 44 are 
reset to the untouched tile state (i.e., tile 42). 

Referring to FIG. 2(b), there are many pixels copied in this frame that were not 

1 5 parts of the "f\ For example, the pixels associated with the letter "s" are copied since 
they are associated with the same touched tile 44. This is the tile size tradeoff discussed 
above. In particular, smaller sized tiles 42 require a larger sized touched tile map 38 
while larger sized tiles 42 require a smaller sized touched tile map 38. A smaller tile size 
would generally be more efficient at copying just the pixels that needed to be copied. 

20 For example, a tile size of 32 pixels by 16 lines is generally a good compromise between 
touched tile map size and copying efficiency. . 

The bandwidth of the secondary frame buffer 14 during the copy operation of the 
shaded areas is used to write the information into the secondary frame buffer 14. The 
secondary frame buffer memory goes through the same access patterns, but instead 

25 performs write operations instead of read operations. 

Referring to FIG. 3, a flowchart 50 of an algorithm for implementing the scan 
synchronized dual frame buffer architecture is illustrated. The memory controller 32 
and/or 2D/3D engine 30 recognizes when a pixel is updated in accordance with 
conventional techniques (step 52). One skilled in the art will recognize that a pixel can 

30 be updated through many different ways and the present invention is not reliant on any 
particular method. For example, a user can update a pixel by writing over existing letters 
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(i.e. modifying existing pixels), inputting an additional letter (i.e. adding pixels) and so 
forth. When a pixel is updated (e.g. such as by a user inputting a letter from a keyboard), 
the memory controller 32 and/or 2D/3D engine 30 notifies the primary frame buffer 
detector 20 and primary frame buffer address generator 34 (step 54). The primary frame 
5 buffer address generator 34 determines the updated pixel's address and notifies the 
touched tile detector 36 (step 56). The touched tile detector 36 decodes the pixel's 
address and updates the touched tile map 38 (step 58). Any pixel that is updated (i.e. 
touched) in the primary frame buffer 12 causes all the pixels in its tile 42 to be tagged for 
copying to the secondary frame buffer 14 at the next pass of the CRT beam (step 60). As 

10 the display 1 1 is being refreshed, the CRT timing generator 24 provides the X and Y 
position information to the primary frame buffer address generator 34, which is in 
communication with the touched tile map 38 (step 62). This information is used to fetch 
the proper location in the touched tile map 38 to pass on to the touched tile detector 36 
(step 64). If the display 1 1 is about to cover an area of a tile 42 that has been updated 

1 5 (i.e. touched) (step 66), the touched tile detector 36 will signal the tile access channel 40, 
secondary frame buffer address generator 28 and FIFO 26 to pass the data from the 
primary frame buffer 12 to the DAC 22 and the secondary frame buffer 14 (step 68). If 
the display 1 1 is not about to cover any updated pixel information, no action is taken. 

In accordance with another embodiment of the invention, the enabling of touched 

20 tile hits are held off until all of the operations on the primary frame buffer 12 are 

completed. This would eliminate any drawing time artifacts from showing on the screen 
by emulating double buffering. The enabling of touched tile hits could also be timed to 
the vertical refresh period of the display 11. All of the tiles 42 could also appear as 
touched with a single command, forcing a complete update of the screen and secondary 

25 frame buffer 14. 

Furthermore, the FIFO 26 could also be expanded to increase the capabilities of 
the present invention, including but not limited to, fimctions such as blending, scaling, 
color space conversion and so forth. The FIFO 26 could also be made to work in tandem 
with the primary frame buffer 12 if bandwidth was not a concem. This would allow the 

30 secondary frame buffer 14 to be the video overlay surface or another graphics surface that 
could be mixed with the output from the primary frame buffer 12. 
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Having now described the invention in accordance with the requirements of the 
patent statutes, those skilled in the art will understand how to make changes and 
modifications to the present invention to meet their specific requirements or conditions. 
Such changes and modifications may be made without departing from the scope and 
5 spirit of the invention as set forth in the following claims. 
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